import './index.scss'
import { Card, Form, Input, Button, message } from 'antd'
import logo from '@/assets/logo.png'
import {useDispatch} from 'react-redux'
import { fetchLogin } from '@/store/modules/user'
import{useNavigate} from 'react-router-dom'

const Login = () => {

  const navigate = useNavigate()
  const dispatch = useDispatch()

  // 表单提交时触发函数
  const onFinish =  async (values) => {

    console.log(values);

      // 触发异步函数提交数据获取token
    await dispatch(fetchLogin(values))

     // 1.跳转页面
    navigate('/')

     // 2.提示用户
    message.success('登录成功')
  }

  return (
    <div className="login">
      <Card className="login-container">
        <img className="login-logo" src={logo} alt="" />
        {/* 登录表单 */}
        {/* validateTrigger 属性代表触发校验的时机，"onBlur"便是失去焦点 * onFinish属性是表单组件点击按钮后提交时会触发的函数     */}
        <Form validateTrigger="onBlur" onFinish={onFinish}>
          <Form.Item 
                name="mobile"
                rules={[
                  {
                    required: true,
                    message: '请输入手机号!',
                  },
                  {
                    pattern: /^1[3,9]\d{9}$/,
                    message: '手机号格式不正确!',
                  }
                ]}
          >
            <Input size="large" placeholder="请输入手机号" />
          </Form.Item>
          <Form.Item
                name="code"
                rules={[
                  {
                    required: true,
                    message: '请输入验证码!',
                  },
                  {
                    pattern: /^\d{6}$/,
                    message: '验证码格式不正确!',
                  }
                ]}
          >
            <Input size="large" placeholder="请输入验证码" />
          </Form.Item>
          <Form.Item>
            <Button type="primary" htmlType="submit" size="large" block>
              登录
            </Button>
          </Form.Item>
        </Form>
      </Card>
    </div>
  )
}

export default Login